<template>
  <div>
    <div class="my-goods-item" v-for="item in list" :key="item.id">
      <div class="left">
        <div class="custom-control custom-checkbox">
          <input type="checkbox" class="custom-control-input" id="input" :checked="item.goods_state" @change="changeState(item.id)"/>
          <label class="custom-control-label" for="input">
            <img
              :src="item.goods_img"
              alt=""
            />
          </label>
        </div>
      </div>
      <div class="right">
        <div class="top">{{item.goods_name}}</div>
        <div class="bottom">
          <span class="price">¥ {{item.goods_price}}</span>
          <span>
            <MyCount :count="item.goods_count" @add="add(item.id)" @del="del(item.id)" />
          </span>
        </div>
      </div>
    </div>
  </div>
</template>

<script>
import MyCount from './MyCount'
export default {
  components:{
    MyCount
  },
  props: {
    list: {
      type: Array,
      required: true,
    },
  },
  methods:{
    changeState(id){
      this.$emit('changeState',id)
    },
    add(id){
      this.$emit('add',id)
    },
    del(id){
      this.$emit('del',id)
    }
  }
}
</script>

<style lang="less" scoped>
.my-goods-item {
  display: flex;
  padding: 10px;
  border-bottom: 1px solid #ccc;
  .left {
    img {
      width: 120px;
      height: 120px;
      margin-right: 8px;
      border-radius: 10px;
    }
    .custom-control-label::before,
    .custom-control-label::after {
      top: 50px;
    }
  }
  .right {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    .top {
      font-size: 14px;
      font-weight: 700;
    }
    .bottom {
      display: flex;
      justify-content: space-between;
      padding: 5px 0;
      align-items: center;
      .price {
        color: red;
        font-weight: bold;
      }
    }
  }
}
</style>
